Longest arithmetic sequence

Time: O(N^2); Space: O(N^2); medium

Given an array A of integers, return the length of the longest arithmetic subsequence in A.

Recall that a subsequence of A is a list A[i_1], A[i_2], …, A[i_k] with 0 <= i_1 < i_2 < … < i_k <= A.length - 1,

and that a sequence B is arithmetic if B[i+1] - B[i] are all the same value (for 0 <= i < B.length - 1).

Example 1:

Input: A = [3,6,9,12]

Output: 4

Explanation:

  • The whole array is an arithmetic sequence with steps of length = 3.

Example 2:

Input: A = [9,4,7,2,10]

Output: 3

Explanation:

  • The longest arithmetic subsequence is [4,7,10].

Example 3:

Input: A = [20,1,15,3,10,5,8]

Output: 4

Explanation:

  • The longest arithmetic subsequence is [20,15,10,5].

Constraints:

  • 2 <= len(A) <= 2000

  • 0 <= A[i] <= 10000

1. Dynamic programming [O(N^2), O(N^2)]

[1]:
import collections

class Solution1(object):
    """
    Time: O(N^2)
    Space: O(N^2)
    """
    def longestArithSeqLength(self, A):
        """
        :type A: List[int]
        :rtype: int
        """
        dp = collections.defaultdict(int)

        for i in range(len(A)-1):
            for j in range(i+1, len(A)):
                v =  A[j]-A[i]
                dp[v, j] = max(dp[v, j], dp[v, i] + 1)

        return max(dp.values()) + 1
[2]:
s = Solution1()

A = [3,6,9,12]
assert s.longestArithSeqLength(A) == 4

A = [9,4,7,2,10]
assert s.longestArithSeqLength(A) == 3

A = [20,1,15,3,10,5,8]
assert s.longestArithSeqLength(A) == 4